// pages/goods_list/index.js
//导入封装的网络请求
import {
  request
} from "../../request/index"
// 导入公共数据文件
const urlList = require("../../commons/common")
Page({

  /**
   * 页面的初始数据
   */
  data: {
    tabs: [{
      id: 0,
      value: "综合",
      isActive: true
    }, {
      id: 1,
      value: "销量",
      isActive: false
    }, {
      id: 2,
      value: "价格",
      isActive: false
    }],
    goodsList: [] //接受返回的商品列表数据
  },
  //接口要的参数
  QueryParams: {
    query: "",
    cid: "",
    pagenum: 1,
    pagesize: 10
  },
  //总页数
  totalPages:1,

  //标题的点击事件 从子组件传递过来
  handleTabsItemChange(e) {
    //1.获取被点击的标题索引
    const {
      index
    } = e.detail;
    //2.修改原数组
    let {
      tabs
    } = this.data;
    tabs.forEach((v, i) => i === index ? v.isActive = true : v.isActive = false);
    //3.赋值到data中
    this.setData({
      tabs
    })
  },
  // 获取商品列表数据
  getGoodsList() {
    request({
        url: urlList.searchDate,
        data: this.QueryParams
      })
      .then(res => {
        console.log(res)
        //获取总条数
        const total = res.total;
        //计算总页数
        this.totalPages=Math.ceil(total/this.QueryParams.pagesize)
        this.setData({
          //拼接了数组
          goodsList: [...this.data.goodsList,...res.goods]
        })
        //关闭下拉刷新的窗口
        wx.stopPullDownRefresh()
      })
  },
  /**
   * 生命周期函数--监听页面加载
   */
  onLoad: function (options) {
    this.QueryParams.cid = options.cid||"";
    this.QueryParams.query = options.query||"";
    this.getGoodsList()
  },

  /**
   * 生命周期函数--监听页面初次渲染完成
   */
  onReady: function () {

  },

  /**
   * 生命周期函数--监听页面显示
   */
  onShow: function () {

  },

  /**
   * 生命周期函数--监听页面隐藏
   */
  onHide: function () {

  },

  /**
   * 生命周期函数--监听页面卸载
   */
  onUnload: function () {

  },

  /**
   * 页面相关事件处理函数--监听用户下拉动作
   */
  onPullDownRefresh: function () {
    //1.重置数组
    this.setData({
      goodsList:[]
    })
    //2.重置页码
    this.QueryParams.pagenum=1;
    //3.重新发送请求
    this.getGoodsList()
  },

  /**
   * 页面上拉触底事件的处理函数
   */
  onReachBottom: function () {
    //判断还有没有下一页数据
    if(this.QueryParams.pagenum>=this.totalPages){
      //没有下一页数据
      wx.showToast({
        title: '没有更多了',
        icon:'error'
      })
    }else{
      //有下一页数据 当前页码++ 重新发送请求
      this.QueryParams.pagenum++;
      this.getGoodsList()
    }
  },

  /**
   * 用户点击右上角分享
   */
  onShareAppMessage: function () {

  }
})